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INFORMATION TRANSFER SYSTEM WITH DYNAMIC DISTRIBUTION 
OF DATA, CONTROL AND MANAGEMENT OF INFORMATION 

5 Background of the Invention 

The present invention relates generally to 
information transfer systems, and more particularly to 
the dynamic distribution and transfer of information over 
a data communications network, for example, the Internet. 

10 The transfer of information using the Internet is 

not centrally managed. The Internet is an amalgam of 
many networks and many host computers. Using the 
Internet, information is stored on host servers and is 
requested using a static address location of that host 

15 server. The Internet does not redistribute data 

according to user requests. Furthermore, the Internet is 
organized into a hierarchy of two tiers, a client tier 
and a server tier. Thus, the Internet does not 
efficiently manage the location of information. 

20 Furthermore, the Internet does not enjoy the advantages 
of a four tier system, and its system resources are not 
managed . 

The Internet is not a consistent behaving network. 
The traffic and load on parts of its infrastructure can 
25 largely vary. Thus, the response time is inconsistent, 
unstable, and unexpected. Therefore, traditional 
Internet tools (i.e. servers, clients) cannot be used "as 
is", if a professional level of interactivity is 
required. 

30 Traditional Local Area Networks ("LANs") or Wide 

Area Networks ("WANs") that employ dedicated 
infrastructure gain stability and dependability based on 
the assumption that the users, the amount of users, and 
the content that ran over the network are expected. In 

35 the case of the Internet, these assumptions can not be 
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made, thus eliminating the use of traditional LANs or 
WANs. 

Summary of the Invention 
In one embodiment, the invention is directed to a 
5 system for transferring data over a network having a 

plurality of client terminals, and a plurality of servers 
connected to a network. An operations management system 
connected to the network monitors and stores 
characteristic data about the client terminals and the 
10 servers. An interfacing system connected to the network 
dynamically distributes data between the servers and the 
terminals as a function of the characteristic data. As a 
result, a portion of the data is stored at the client 
terminal . 

15 Implementations of the invention may include one 

or more of the following. The network may be a LANnet, a 
WANnet , the Internet or an Intranet. Each of the client 
terminals may be a personal computer, an organizational 
personal computer, or a stand-alone terminal. The stand- 

2 0 alone terminal may further include hardware to execute 
the loading of smart cards, the reading of magnetic 
cards, or the processing of videographics. The servers 
may include an information server, a transactional 
server, or an external server. The transactional server 

25 may perform a financial transaction or a personal 

transaction. The network may be described as a four-tier 
model. The system may also include a graphical user 
interface to display a portion of the data on the client 
terminal . The system may also be operable to interact 

30 with a plurality of third party applications. The 

interfacing system may be a request broker system. The 
system may also include a telecommunications device to 
connect to the network to access data from the servers. 
The system may also include an optimization system to 
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distribute data between the client terminals and the 
servers. The characteristic data may include a plurality 
of static or dynamic parameters associated with each of 
the client terminals, or a usage pattern associated with 
5 the client terminals. 

In another aspect, the invention is directed 
towards a method for transferring data over a network 
having a plurality of client terminals and a plurality of 
servers. The method includes establishing a data 

10 communication path between the client terminals and the 
servers. A database of characteristic data associated 
with the client terminals and the servers may be 
generated. The method further includes dynamically 
distributing data between the client terminals and the 

15 servers as a function of the characteristic data and the 
database. As a result, a portion of the data resides in 
the client terminals, and a portion of the data resides 
at the servers. 

Implementations of the invention include the 

20 following. The establishing step may further include 
loading an application onto one of the terminals, and 
establishing the data communication as a function of 
specifications of the application. 

In another aspect, the invention is directed to a 

2 5 computer-based method of processing information 

dynamically between a plurality of client terminals and a 
plurality of servers. The method includes the steps of 
establishing a data communication path between the client 
terminals and the servers; generating a database of 

30 characteristic data associated with the client terminals 
and the servers; and dynamically distributing data 
between the client terminals and the servers as a 
function of the characteristic data in the database. As 
a result, a portion of the data resides at the client 
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terminals and a portion of the data resides at the 
servers . 

Other advantages and features of the present 
invention will become apparent from the following 
5 description, including the drawings and claims. 



Brief Description of the Drawing 
FIG. 1 is a constructional diagram of an 
Information Transfer Network System in accordance with 
the present invention. 
10 FIG. 2 is a block diagram of the components and 

architecture of the Information Transfer Network System 
of FIG. 1. 

FIG. 3 is a block diagram of the client and the 
server of the Information Transfer Network System. 
15 FIG. 4 is a constructional diagram of the general 

architecture of the Information Transfer Network System. 

FIG. 5 is a block diagram and flowchart of the 
processing sequence of a presentation system in 
accordance with the system of FIG. 1. 
20 FIG . 5A is a block diagram of the object oriented 

data model used to transfer information between the 
presentation system and a request broker. 

FIG. 5B is a block diagram of a bandwidth 
optimization system. 
25 FIG. 5C is a block diagram of the request broker 

data model . 

FIG. 6 is a block diagram of the JAVA Applet for 
the client terminals of the Information Transfer Network 
System. 

30 FIG. 7 is a flowchart of the server of FIG. 3. 

FIGS. 8a and 8b are a block diagram of a database 
design in accordance with the present invention. 
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FIG. 9 is a block diagram of a visual data 
management tool . 

FIG. 10 is a table of a database example depicting 
the structure of a database of the system of FIG. 1. 
5 FIG. 11 is a table of the database example 

depicting the object link types of the database of FIG. 
10 . 

FIG. 12a is part A of the table of the database 
example depicting the data in the database of FIG. 11. 
10 FIG. 12b is part B of the table of the database 

example depicting the data in the database of FIG. 11. 

FIG. 12c is part C of the table of the database 
example depicting the data in the database of FIG. 11. 

FIG. 13 is an illustration of a classification 
15 tree and associated data items of the database example of 
FIG. 11. 

Description of the Preferred Embodiments 
FIG. 1 shows a block diagram of an implementation 
of an Information Transfer Network System 100. 

20 Generally, system 100 provides a medium for presenting 
visual information (multimedia) , performing business 
transactions, and providing advanced services to 
customers through publicly accessible terminals or home 
personal computers connected to a network. The system 

25 includes an infrastructure 2. Infrastructure 2 may be a 
LANnet, WANnet , Internet or Intranet. References to the 
terms "backbone " and "infrastructure" are to be similarly 
construed to represent a network for supporting the 
distribution of information, for example, data to and 

30 from a multitude of terminals and servers connected to 
the network. The system also includes one or more client 
terminals 1 connected to backbone 2. Client terminals 1 
may be stand-alone terminals which are able to process, 
for example, credit card information or execute video 
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applications. The system also includes a plurality of 
personal computers "PCs" 3, an organization network 5, a 
data management system 6, and a control management system 
7. The data management system 6, the control management 
5 system 7, the organization network 5 and PCs 3 are 

connected to infrastructure 2 . Data management system 6 
manages existing and new entry data tasks. Data 
management system includes a copy of information located 
in the database of information server 8. At predefined 
10 periods, the database of the information server 8 is 

updated by the data management system 6 . The database of 
information server 8 is the "formal" active database of 
system 100. 

Organization PC terminals ("OPCs") 4 and stand- 
15 alone networks 1' are connected to infrastructure 2 via 
organizational network 5. Stand-alone terminals 1 and 
1', PCs 3 and OPCs 4 may execute similar applications. 
It should be noted, however, that stand-alone terminals 1 
and 1' may include hardware and peripherals which may 
20 execute additional applications, for example, loading 

smart cards, reading magnetic cards, and processing video 
graphics . 

System 100 also includes an information server 8, 
a transaction server 9, and an external server 10. A 

25 content provider server 11 is also shown connected to the 
network backbone 2 via external server 10. The system 
100 may also include thousands of terminals, servers, and 
network facilities . 

Generally, PCs 3 connect to infrastructure 2 in a 

3 0 conventional manner using the hypertext transfer protocol 
(HTTP) . This initiates a request for a secure or non- 
secure connection to information server 8 via backbone 2. 
Once the PC is verified and identified, a connection 
between the information server 8, and the PC 3 is 

35 established. Once the connection is established, the 
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type of application to be executed is determined. The 
specifications of the application may be loaded onto the 
terminal from the server or from a hard disk. The 
specifications are used to determine if a non-secure or 
5 secure connection should be used. (See FIG. 6) For 
example, financial transactions or transactions 
containing personal information may require a secure 
connection. 

In one operating process, a financial or personal 

10 transaction may be requested by one of the terminals. In 
this regime, the information server 8 connects the 
application with the transaction server 9 via the 
information server 8. Transaction server 9 may process 
the request locally, or may establish a remote connection 

15 to a third party clearing system. 

In another processing regime, the application may 
require additional information that is not located on 
either of the information server 8 or transaction server 
9. In such a case, the information may be retrieved from 

20 content provider server 11. To receive the necessary 
information, information server 8 establishes a 
connection via an external server 10 to a content 
provider server 11. In this regime, external server 10 
establishes a gateway to content provider 11. 

25 Once the type of connection is established, an 

application channel is formed. The application channel 
is used to transmit information from the database of 
server 8 to PC 3 upon the request of the user. The 
information may be stored or displayed by the user. 

30 FIG. 2 is a more detailed block diagram of the 

components and architecture of the system 100. The 
Client 12 includes Smart Decompression Engine 13 
connected to Browser 14 . Browser 14 includes Java Applet 
15. Browser 14 is connected to External Devices 16. 

35 External Devices 14 is connected to Control and 
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Management Agent 17. Client 12 is connected to Secure 
HTTP Channel 31, which is connected to Server 18. Server 
18 comprises Smart Compression Engine 19 connected to a 
Control and Management Agent 21, which is connected to 
5 services and a database. Control and Management system 
23 includes Configuration Database 26, Agent Manager 27, 
and Optimizing Engine 28. Optimizing Engine 28 includes 
Mathematical model 24 and Optimization Algorithms 25. 
Data Entry System 29 includes Visual database 

10 manipulation tool 30. 

FIG. 3 is a detailed block diagram of the Browser 
14, Java Applet 15, Secure HTTP Channel 31 and Database 
22 components and architecture. Browser 14 comprises 
Java Virtual Machine 14. Java Applet 15 comprises 

15 Application Classes 34. External Devices 16 are 

connected to Java Applet 15 by Com Bridge 32. External 
Devices 16 are connected to Control and Management Agent 
17 by SNMP 33. Visual Data Management 29 is connected to 
database 22 by Visual Data Insertion channel 31' . 

20 External Services 39 are connected to Services Database 
20. Services Database 20 includes Service Broker 35, 
Java Classes 36, Application Data 37 and Multimedia Data 
38. 

FIG. 4 shows a constructional diagram of the 
25 general system architecture of the Information Transfer 
Network System 100. Request Broker 40 comprises a HTTP 
Request Broker 41 connected to Request Broker Interface 
Modules 42, and a Content and Software Transmitter 43 
connected to the Profiles Manager 44 . The Request Broker 
30 Interface Modules 42 are connected to Clients 12 and 
Application Services 20. Content and Software 
Transmitter 43 is connected to Clients 12 and Databases 
22. External Services 39 are connected to Application 
Services 20. 
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The Information Transfer Network system 
architecture is based on a unique 4 -Tier model 
architecture system that allows third-party components to 
be integrated in a plug-and-play fashion. This 
5 architecture allows the Information Transfer Network 
system to use different Graphical User Interface ("GUI") 
and multimedia interfaces to distribute software and 
information over the network, and to interact with third 
party applications and databases. The Information 

10 Transfer Network system uses Object Oriented Design 

(OOD/OOP) , a component based system, which permits the 
re -use and re-purposing of functions. 

The first tier, the Presentation system, resides 
on the client machine. The other tier systems may also 

15 reside on the client machine, on a single server, or 

across multiple servers over the network. Tiers can be 
duplicated on multiple servers for security, load 
balancing and optimization of system performance. The 
separation of these functions into tiers enables the 

20 system to adapt to different environments and technology 
standards. For example, the Presentation system can 
adapt itself for use by a home PC user (Internet) , or 
specialized terminals. 

FIG. 5 shows an implementation of the processing 

25 sequence of the presentation system. The presentation 
system incorporates a thin-client methodology, thereby 
containing only minimal functions required to display 
(GUI), and the drivers for essential internal devices 
(sound card, video card, network card, etc.). All 

30 advanced interface features, business logic, and services 
may be loaded onto the client terminal dynamically on 
system demand. The information or intelligence at the 
client terminal varies according to the services demanded 
by the user. The Presentation system is implemented 

35 using Java architecture, and executes inside a standard 
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web browser that supports a Java virtual Machine. 
Suitable browsers include the Microsoft Internet Explorer 
version 3 (IE3) or the Netscape Navigator version 3. 
Java is a commercially available multi-platform Object 
5 Oriented language that adheres to the Client/Server 

model, and may run on any machine that has a Java Virtual 
Machine . 

Referring to FIG. 4, the Presentation system 
passes all requests for information or services through 

10 the Request Broker system 40. The presentation system 
may interact with the Request Broker system through the 
Request Broker Interface using, for example, Java, JDBC, 
CGI, ActiveX, CORBA, HTTP, Network Pipe or other 
interface protocols. 

15 Java Applets are small blocks of computer code 

which may be loaded onto the Client 12 from the Server 18 
to be executed by the Client 12. Java Applets may 
perform interfacing between the Presentation system and 
the Request Broker 40. 

20 The following are protocols which may be used to 

perform various functions of the presentation system. 

Java Database Connection ("JDBC") is an 
incarnation of the well- known Open Data Base Connection 
("ODBC") protocol that interfaces with different types of 

25 databases. The JDBC is the Java flavor of ODBC developed 
for the Java language. 

The Common Gateway Interface ("CGI") may run 
scripts on the server 18 to translate client requests 
into calls for information to external programs, 

30 applications, or servers. 

ActiveX is Microsoft's product based upon Objects 
interfacing model (OCX) adopted for internet components 
interfacing. An ActiveX component is a code that may run 
on the client 12 to handle interfacing with the server 

35 18 . 
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Common Object Request Broker Architecture 
{"CORBA") allows applications to communicate with each 
other irrespective of the type and location of the 
application. CORBA defines an Interface Definition 
5 Language (IDL) and the Application Programming Interface 
that enable client to server object interaction. 

Network Pipe is a dedicated protocol used for 
streaming data. This protocol is used to establish or 
maintain a continuous flow of data, for example, in a 
10 telephone conversation or video clip. 

The presentation system is insensitive to the 
content being presented, since the functions required to 
display material are downloaded as objects with the 
material. Multiple GUI templates may be created to offer 
15 different displays for the same content without 

duplicating the other tiers. For example, two different 
client terminals, such as PC 3 and OPC 4 could display 
different views of the same content using the same tiers. 

Generally, the presentation system will start the 
20 application by executing HTML File 50, and will load main 
Java application 52. The presentation system, using main 
java applets 52, will present Java screen A 54 to the 
user. Java screen A 54 comprises Java object -Movie 60, 
Java object-Button 56, and Java obj ect -Button 56. If 
25 Java obj ect -button 56 is activated, the presentation 
system will load Java Screen B 54' . If Java 
obj ect -button 58 is activated, the presentation system 
will load Java Screen C 54" . 

FIG. 5A shews a block diagram of the data model 
30 used to transfer information between the presentation 
system and the request broker. The Presentation system 
includes a Graphical User Interface. The GUI Multimedia 
Components of the Information Transfer Network system 
include: I a) JAVA-HTML Classes that enable the use of 
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HTML within Java applets, including rich text format, 
pages layout, and hyperlinks (between items in Java 
application) ; b) controlled WWW Links Java applets that 
can completely control a standard HTML session. This 
includes replacing browser toolbars and menus with Java 
navigation toolbars, and capturing and filtering all 
hyperlinks; c) peripherals interaction applets. Object 
60 comprises various data objects to be presented by GUI 
to the presentation system. 

FIG. 5B shows a block diagram of the bandwidth 
optimization system. The optimization system includes 
Bandwidth Optimization Methods for compression and 
decompression of GUI components and Java Classes. The 
Client 12 comprises Control and Management Agent 17. 
Server 18 comprises Control and Management Agent 21. 
Control and system 23 comprises Configuration Database 
26, Agent Manager 27, and Optimizing Engine 28. 
Optimization Engine 28 includes Mathematical model 24 and 
Optimization Algorithms 25. Control and Management Agent 
0 23 is connected to the Client 12 and Server 18 using 
Agent Manager 27. Agent Manager 27 is connected to C&M 
Agent 17 and C&M Agent 21. 

FIG. 5C shows a block diagram of Request Broker 
data model. Java Screen 90 comprises Java Object -Item 
5 List 92 and Java Obj ect -Keyboard 94. Request Broker 40 
is connected to database 22 using Database Driver 106. 
Request Broker 4 0 is connected to presentation system 
through Java Screen 90 using Optimization Agent 104 and 
Translator 102. 
0 The Information Transfer Network system 100 

utilizes a Forms Generator/Processor that includes: a) 
Form Filling system that enables users to complete self- 
service forms on screen for electronic submission or 
printing; and b) Validity Checking system. The Forms may 
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have embedded validity checking, which runs on the client 
12. 

The Information Transfer Network system 100 
utilizes Authoring and Data Management Tools including: 
5 a) Application Generator- Rapid Application Development 
(RAD) tools for building self-service applications; b) 
Object-Oriented Dynamic Display System that Reads GUI 
objects from databases on-the-fly, and displays them 
according to Properties and Methods; and c) Visual Data 
10 Management- Visual tools for organizing, classifying, and 
maintaining data items. 

The Information Transfer Network system 100 
utilizes Database Technology that includes a Generic 
Database Design, a Standardized Data Modeling may be used 
15 to represent all applications, and GUI objects. This 
permits search, data entry, and database distribution 
tools to be operated on every application without 
modification. 

FIG. 6 illustrates a start-up routine for the JAVA 
20 Applet for the Information Transfer Network System 100 
client terminals. 

FIG . 1 shows a flowchart of the processing 
sequence of the applications system of Server 18. 

FIGS. 8a and 8b show a block diagram of the 
25 generic database design. The basic concept of the 

database model is based on three components: OBJECTS, the 
PROPERTIES of each object, and the LINKS between the 
objects. The database model contains the META-DATA which 
represents the structure of the data, and determines the 
30 laws of data including OBJECT_TYPES : the types that the 
objects may be; PROPERTYJTYPES : the types of properties 
each object may have; DATATYPES: the data types 
(numeric, string, etc.) a property may be; LINK_TYPES : 
the kinds of links that may be between object types; and 
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LANGUAGES the different languages that the data may be 
translated to. 
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Several architectural and functional components of 
system 100 will now be described in detail. 

Request Broker System 

The Request Broker system 40 acts as a link 
5 between the Applications system and the Presentation 
system. The Request Broker system 40 interprets the 
request from the Presentation system, and locates the 
appropriate Request Broker Interface server. Suitable 
servers include Oracle, Lotus Notes, and GIS. Request 

10 Broker System 40 passes the request to the server 
application, receives the results, and returns the 
results to the Presentation system. Because the 
Presentation system interacts with the servers only 
through the Request Broker system 40, the Presentation 

15 Layer does not maintain information concerning the 

location of the loading of the application. A single 
Request Broker system may serve multiple applications, or 
a specialized Request Broker system may be implemented 
for a single application. 

20 The Request Broker system interfaces to the 

Applications system (Business Logic) layer using specific 
protocols for each type of server. For example, 
information applications will use the Oracle Web Server 
protocol, and Java will be used to connect with servlets 

25 (server-side applets) . 

Request Broker system architecture results in an 
open environment that can integrate new types of servers. 
For example, a new third-party electronic commerce server 
that implements SET security may be integrated into the 

30 Request Broker system. 

A single Request Broker system may handle 
multiple, simultaneous requests. This allows traffic to 
be monitored and controlled, and eliminates the need to 
run a separate process for each request as would be 
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required using the CGI protocol, or direct requests from 
the client terminals to the applications. 

Application System (Business Logic System) 

The Application system tier contains all of the 
5 applications and services to be used by the end-user. 

This tier may include applications developed specifically 
for the Information Transfer Network system 100, or 
applications from third parties, written in any standard 
language or with any tool . 

10 For example, third-party applications that utilize 

a world-wide- web interface may interface with the 
Request Broker system using the World Wide Web Request 
Broker Interface. Applications that do not utilize a 
world wide web interface may interface with the CORBA to 

15 Java, and Java to CORBA Request Broker Interface modules. 
Thus, the Information Transfer Network system 100 has the 
ability to incorporate or integrate third-party 
applications which may run on separate computers, or even 
within legacy systems such as mainframes. 

20 Database System 

The Information Transfer Network system 100 may 
use the industry standard Oracle 7.3 RDBMS engine for its 
applications, and meta data storage. The applications 
may interact with most standard RDBMS (Informix DB/2 SQL 

25 Server) or non- RDBMS (Xbase, IMS) . Third-party 

applications may use any database or combination of 
databases on any platform. 

Databases may be distributed across multiple 
servers over the network as required to optimize 

30 performance. For example, video clips can be considered 
as part of the same logical database as other content 
(from the Request Broker system point of view) , even 
though the data may be physically located on a 
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specialized video server, or possibly on the client 
terminal machine. 



Java Architecture 

The architecture of system 100 is based on object 
5 oriented design using, for example, Sun Java 

architecture. Java provides the ability to download 
objects (classes) as they are required. Suitable 
development systems include Sun Microsystems JDK 1.1.1, 
Microsoft J++, Symantec Visual CafJ Pro, Borland Jbuilder 

10 and Microsoft SDK 2 for Java, and Java Beans. A single 
Java Bean component may function as a first-class 
component within a range of applications, including 
applications developed in Visual Basic, Visual C++, Word, 
Excel, and Internet Explorer. 

15 An Active-X bridge Java Bean will enable the 

Information Transfer System to incorporate a wide range 
of available Active-X controls, without relying on its 
proprietary Act ive-X/ Java COM Object solution. 

The present invention provides the following Java 

20 Packages: a) Dynamic Display Package: which reads the 
properties and methods of objects to be displayed, and 
displays them according to these properties; b) Display 
Package which displays and fully controls an HTML window 
within a Java page; executes hyperlinks to related 

25 content, browses Web sites from within the Java 

environment using a customized toolbar, and controls and 
filters links to the WWW; c) Internet Optimization 
Package compression graphic classes for low-bandwidth 
users; d) Database Connection and Manipulation Package 

30 connects to Oracle DB and other databases, searches and 
retrieve information, and e) Peripheral Support Package 
which handles Device drivers to communicate with 
peripherals . 
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The system may also include the following: a) 
forms generator that includes off-line tools to scan, 
OCR, and create electronic forms, display forms on- 
screen, real-time filling of forms with basic validity 
5 checking; submitting and processing of form results, and 
printing of forms (blank or completed) ; b) Advanced 
Search Engine: Soundex; Thesaurus; Morphology (example: 
lingual = language) ; expand search to WWW; c) Virtual 
Reality Interface which simulate real world reality in an 

10 interactive 3-D world (e.g. a virtual supermarket that a 
user can "shop in".); Browse the 3-D world connects items 
in the 3-D world to Database items; and d) Advanced 
multimedia capabilities, which include streamed Video, 
and Audio- supports rich video and audio; Full motion 

15 Animation - high performance 2.5D animations; Spatial 
Audio for Java- provides 3D sound. 

Internet Technologies 
Browser 

The Information Transfer System thin-client is 
2 0 designed to operate inside any standard web browser with 
a Java Virtual Machine. The browser may be customized to 
fully control the GUI. For example, the standard browser 
buttons, toolbars, and menus may be replaced with a 
multimedia GUI that is suitable for mouse or touchscreen 
25 use. Using Java Classes, help functions, sounds, and 
other multimedia capabilities may also be added to the 
interface . 

Software running within the browser environment 
communicates with the hardware through a Component Object 
30 Model Object (COM Object) that controls device drivers 
(e.g. card readers, coin machines, laserdiscs, and video 
cameras) . The COM object can interface with and activate 
Microsoft Active-X controls, such as NetMeeting Video 
Conferencing. This integration of Java and Active-X may 
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be facilitated through the Java Active-X Bridge Java 
Bean, rather than through the COM object. The thin- 
client may be extended and enhanced using third-party 
browser plug-ins. This is particularly beneficial for 
5 providing enhanced multimedia effects for the GUI, such 
as Virtual Reality Modeling Language (VRML) for 3-D 
interfaces . 

HTML Manipulation 

The Information Network System client integrates 

10 the Java Classes, which support HTML 3.2 documents for 
display of Rich Text Format (fonts, colors, point size) 
and images on-screen. The HTML document may contain 
hyperlinks to related information items within the 
application, or to related sites on the World Wide Web 

15 ("WWW") . Upon linking to a WWW site, the screen displays 
the site in a frame on the upper portion of the screen. 
The Java-based navigation GUI panel interface is 
displayed on the lower portion of the screen. The GUI 
provides the essential functions for Web Browsing, with 

20 all browser toolbars and menus removed from the screen. 
This feature is achieved by first loading a special HTML 
page which consists of two frames. The lower frame 
displays a Java applet containing a multimedia GUI. The 
lower frame controls the upper frame, which contains the 

25 linked HTML page. This is implemented completely in 

Java, and does not rely on a browser or platform specific 
API. WWW links may be filtered in order to control or 
limit access to specific sites. An on-screen keyboard 
may be used to enter specific URLs through a touchscreen. 

30 Optimization of Network Traffic 

Real-time compression techniques may be 
implemented to move information and applets from the 
server 18 to the client 12. Upon receiving a request, 
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the server determines what type of network connection 
exists. A fast LAN connection may be sent full quality, 
uncompressed files including text, images, video, and 
Java Classes. For slower WAN connections, the server may 
5 compress the files in real-time, which may then be 

transmitted over the network and decompressed at runtime 
by the client. Each type of information item has a 
unique compression method, which is most suitable for the 
specific item. For example, JPEG compression is used for 
10 images, and CAB or JAR compression is used for Java 
Classes. The JAR technology is also capable of 
compressing data information and graphics in addition to 
the Java classes. For images, compression ratios of 1:10 
may be achieved using JPEG, 

15 Channel Technology (push) 

One standard for accessing information through the 
Internet is known as pulling, whereby users request 
specific sites through a Web browser. The sites are then 
viewed in real-time, as they are loaded. Another 

20 standard for accessing information on the Internet is 
Push technology, which sends information to a client 
terminal automatically. Information may be general 
purpose content, or specific content based on a profile 
or set of parameters established in advance by/for the 

25 user. Content is delivered as different channels. Each 
channel offers different types of content, and the user 
may specify how often the channel should be updated. For 
example, a user could subscribe to a newspaper channel in 
order to receive a customized daily (or more frequent) 

30 newspaper based on his/her specific topics of interest. 



Integrated Internet Applications 

The Information Transfer Network 100 may integrate 
standard Internet-based applications. For example, e- 
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mail clients, newsgroup readers, chat rooms, and access 
to proprietary online services (AOL, CompuServe, MSN, 
etc.) may be integrated into specific applications. The 
integration may be performed by Active-X to Java COM 
5 bridge, or through a CORBA server to activate remote 
objects in third-party applications. For example, an 
application may offer an electronic suggestion box, which 
will forward suggestions via e-mail to the intended 
recipient. The HTML interface allows users to search the 
10 Internet within a controlled and filtered environment. 

Firewall and Security 

The Information Transfer Network system 100 
integrates a "firewall" to secure servers and systems 
residing on the Internet infrastructure. This allows the 

15 system terminals to be networked through the Internet, or 
through private Intranets. When connected through an 
Intranet, the terminals may still offer access to the 
Internet via a firewall protected gateway at the server. 
The firewall encrypts data between the client and server 

20 when networked through the Internet, and controls access 
in and out of the system. A SSL secure channel method 
may be used to provide additional security for 
transaction data, for example, when performing a 
financial transaction with server 9. 

2 5 Network Computer (NO 

The Java-based system may be executed on NC 
machines being developed by, for example, Sun, Oracle, 
and IBM. The system may be downloaded to the terminal 
and run under the Java OS. 



3 0 Advanced Multimedia and Graphics Technologies 



The Information Transfer Network System 100 
incorporates full multimedia and graphics capabilities. 
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Video and audio may be streamed when delivered from the 
server to the client. This allows the user to view the 
video concurrently, while it is being downloaded. 

The Information Transfer Network System 100 may 
5 also show video clips as part of the Interface (in MOV or 
MPEG format using H.263 standard for video and G723 
format for audio. Video Conferencing (2 -Way Video) may 
be employed, such as video conferencing, including white 
board, document sharing, audio-only Conferencing, and 

10 group Conferencing. Also, video cameras may be used to 
identify users at a terminal, and as part of applications 
that may require a photo such as a Drivers License 
application. Other applications include Rich Text Format 
and HTML and virtual Reality Modeling Language (VRML) 

15 Interface in which 3-D interfaces can emulate real -word 
situations. For example, a VRML supermarket, which 
allows a user to stroll the aisles, and place items in a 
3-D virtual shopping cart, may be employed. Cosmo VRML 
plug-in for displaying 3-D virtual world interfaces may 

20 also be employed. Applications may relate from 3-D items 
in the virtual world to information items in a database. 
In the example above, a user could select a grocery item 
in a 3-D interface, and retrieve nutrition information 
from the database. Geographic Information Systems (GIS) 

25 which include vector and raster maps of the entire United 
States and other countries may be implemented. Any 
address (such as ATM locations) can be geocoded and 
plotted on a map, and a routing system can produce point- 
to-point driving directions to provide transit maps and 

30 point-to-point directions. 

Advanced Services and Applications 
Forms Generator /Processor 

The forms generator scans paper-based forms and 
converts them to HTML documents using OCR technology. 
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Form blanks are automatically converted to fields which 
may accept data. Java Applet may be used to process the 
forms from the form generator. Validation functions may 
be added to each field to perform data checking and 
5 validation at the client. For example, an account number 
may be verified by the form processor using a check- 
digit. Blank or completed forms may be outputted to a 
printer or form input may be submitted to an application, 
or a database on the server. 

10 Computer-Telephone Integration (CTI) 

Server-based software modules enable users at a 
terminal to connect into a public switched telephone 
network to access information for example, a hotel 
location. The CTI applications are implemented using 

15 Microsoft standard Telephone API (TAPI) , running on a 

Windows NT server with a Dialogic voice/modem card or any 
other voice/modem card which is Microsoft TAPI compliant. 
The server side of the application is developed using 
JTAPI . A two-way CTI application, where an application 

20 can interact with a person on the other line, is also 
possible. In this type of application, the end-user 
would not speak directly to the other end-user. Instead, 
a server may speak" using text-to-speech synthesis 
(DSP) , and receive responses using touch- tones (DTMF) . 

25 The responses may then be converted to messages for 
display on the end-user's screen, and the session may 
continue. The system allows users to connect with 
businesses (e.g. small hotels) that are not computerized, 
while still allowing the content provider server 11 to 

30 control the transaction. The system may also allow 
communication to take place across language barriers. 
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Multilingual Capabilities 

The Information Transfer Network system 100 
supports multilingual audio and bi-directional text 
display, including Latin and non-Latin characters. 
5 Languages may be switched on demand, for example, between 
English, Spanish, French, German and Hebrew. 
Multilingual technology through special Unicode character 
sets may be controlled by Java Classes on Windows-based 
on non-Windows based machines. The Dynamic Presentation 
10 Generator (described in detail below) provides for 
multiple languages within an application. 



Authoring and Data Entry Tools 

Rapid Application Development (RAD) contains a set 
of tools that enable non -programmers to design, build and 

15 administrate complete applications, which include GUI, 
interactive features, data modeling, and content 
management. Each application contains MET A data to 
describe the application's structure. Therefore, every 
application data model and GUI is modeled as a set of 

20 objects that have properties (attributes) , methods 

(actions that are made during the user interaction) , and 
links to other objects to which they relate. 

When an application is running, all the objects 
which contain the current GUI interaction are loaded 

25 dynamically to the presentation system, and display 

themselves according to their own display methods. When 
a user executes a function, e.g. pressing a button, the 
appropriate Object Method is activated, which may then 
activate another object (e.g. display a screen, play a 

30 video, run search, etc.) 

An application may be loaded using the following 
steps. A graphics template (buttons, backgrounds, logos, 
etc.) is chosen from a library. The data Objects, 
Properties, and Actions that implement the application 
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GUI and user interactions are defined. For example, when 
the application uses buttons, one has to define the 
buttons' shape, color, x-y coordinates, and actions that 
are executed when the button is pressed. The related 
5 objects are then linked, and the resulting application 
model is stored in the generic database model. 

During operation (runtime) , the dynamic 
presentation generator reads all the GUI objects of the 
application from the database model for display. One 

10 routine, Reflection (during runtime), allows the 
application to identify every object type (loaded 
dynamically), retrieves information about the object's 
capabilities, and links to other objects. Another 
routine, Transparent Canvas, allows new objects to be 

15 displayed without interfering with background objects or 
currently displayed objects. 

The data entry tool enables insertion and 
management of content and classification data that 
relates to the application. The data entry tool visually 

20 browses the classifications and data. Once the database 
updates are inserted, the system's distribution tools 
distributes all the information to the appropriate 
databases, according to the optimization algorithm. 

Database Technologies 

25 The Information Transfer Network 100 allows 

application data and GUI to be described as a set of 
Objects that have Properties (attributes) , Methods 
(actions) , and links (connections to other objects) . A 
unique generic database model may model, store, and 

30 manipulate the Objects, Methods, Properties, and object 
links of any type of application data model. The generic 
model also stores Meta Data, which is used to display and 
interact with the GUI of the application. 
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Example of using the Generic Model to implement a 
Companv / s data system 

FIGS. 10, 11, 12a-c and 13 illustrate an exemplary 
application using system 100. Two main classifications 
5 are shown: Computers and Food. Within each 

classification, there are associated companies: G, M, and 
I. Each Company has products such as Multimedia Stations 
and Terminals. 

Table 1 of FIG. 10 and Table 2 of FIG. 11 show the 

10 "META data" which describes the Object Types, Properties, 
and Link Types. Table 3 of FIGS. 12a - 12c show sample 
data filled into the model established in Tables 1 and 2. 
FIG. 13 is an illustration of the classification tree and 
associated data items of the example. 

15 This model permits many different applications to 

share a common database design. Therefore, the same 
search and statistical analysis tools may be used within 
any application without modification. Thus, the database 
design, search, data entry, and statistics tools are 

2 0 independent of the content being represented. 

Dynamic Distribution 

Application databases (which contain information, 
pictures, video, etc.) may be distributed and replicated 
across the network to optimize overall system 

25 performance. Due to the frequently changing environment 
in application and information demand, communications 
bandwidth, and the facilities in the station, information 
may be redistributed across the network. For example, if 
there is high demand for a certain video clip, the clip 

30 may be distributed for storage on a server near the 
terminal, or even on the terminal hard drive. 

The decision of where and how to distribute 
databases is made by the system. The decision is a 
function of all system parameters. The system also 
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determines the optimal distribution of information to 
achieve the most efficient performance. The application 
is not modified upon changes in the database 
distribution. 
5 The following describes the process and 

architecture of the dynamic distribution and system 
optimization systems. 

Statistical Analysis 

Every operation (menu choices, coordinates of 
10 screen touches) within the system is recorded in a 
database table. This data may be analyzed using 
statistical analysis tools, including Oracle tools, in 
order to determine usage patterns, and to improve or 
alter system performance. Usage patterns, such as 
15 printer usage may be analyzed to predict, for example, 
when the printer will run out of paper. The number of 
screen touches of a component of the GUI may also be 
monitored . 

For each user operation, and some of the system's 
20 activities, a text entry is added to a log file which 
maintains a statistical record. Each entry line of the 
log file records the time and date stamp of the action, 
the type of action, and some general system status 
information the status information may be used to decode 
25 the action recorded in relation to the system's operation 
status. The log file is transmitted to the control and 
management system on predefined schedules or on a 
specific request from the control and management system. 
The log file may then be analyzed to determine the needs 
30 of the system including maintenance and correction. 

Other types of information may also be retrieved from the 
log file, including specific application's parts usage 
and user interface usage. 
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Systems Management Tools 

The Information Transfer Network system 100 is a 
large, complex, changing, non-deterministic network, 
handling massive amounts of information, transactions, 
5 and services. To manage this network, an Optimized 

Integrated System Management Architecture (OISMA) may be 
used. The OISMA may perform the following functions: a) 
consolidate a central console that monitors all system 
components; b) distribute regional and functional 

10 specific consoles; c) determine various system alerts of 
system B , (pager, fax, sound, send messages to sub- 
contractor system) ; d) perform automatic recovery actions 
to recover from problems; e) takeover any station and 
execute commands from a remote source; f) track and 

15 analyze problems on system using help desk tools; g) 
track and manage the flow of system transactions; h) 
monitor usage patterns and statistics; i) record 
automatically inventory related to network inventory 
autodetect and control B plug-and-play installation of 

20 components; j) control hardware/Software version and 
configuration; k) perform preventive Maintenance 
Management and 1) maintain Central backup. 

Systems Management Technologies 

The following are management tools which may be 
25 incorporated into system 100. 

Simple Network Management Protocol (SNMP) - 
Framework of OISMA, enables agents across the network to 
communicate with central management tools. 

Integration of management tools into a four tier 
30 Architecture: Each tier will have agents that receive 
orders, collect data, and report back to the management 
system. 
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Integration of third-party SNMP agents: Agents for 
specific software (e.g. Oracle Database), hardware 
devices, or operating systems. 

Software and Information Deployment and 
5 Synchronization: Oracle tools, SMS, and other tools for 
distribution and synchronization. 

HP Open View Network Management Framework - GS 
intends to integrate this set of network and hardware 
management tools. 

10 Network Control and Management 

Commercially available control and management 
systems, such as the Trivoli system from IBM and the SMS 
system from Microsoft, may be used in the information 
transfer network 100. 

15 System Optimization 

System Optimization provides the optimal service 
on all terminals over time. Services include fast 
response time, availability of services and peripherals 
(printer, network, etc.), and appropriate adaptation to 

20 terminal capabilities (e.g. home PC with low -bandwidth, 
machine without video capability, etc.) 

Optimization may be achieved by one or more of the 
following. Static parameters of the hardware and 
peripheral on any of the terminals may be measured. For 

25 example, the type of memory, the type of terminal, or the 
type of network connection to the terminal may be 
measured. Dynamic parameters including the current 
available bandwidth, server utilization, the location and 
nature of the data, and the location of the selective 

30 application or service may be monitored. The system may 
track the number of uses of a particular application or 
service over time. 
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Using the above techniques, the system determines 
the optimal message to fulfill user request. Further, 
this optimization may be performed at preset schedules 
during operation to redistribute applications and content 
5 across the network. 

The present invention has been described in terms 
of number of embodiments. The invention, however, is not 
limited to the embodiments depicted and described. 



-WO 98/59460 



PCT/US98/12947 



- 30 - 



What is claimed is: 



1 . 



A system for transferring data over a network 



comprising : 



a plurality of client terminals connected to 



5 the network; 



a plurality of servers connected to the 



network; 



an operations management system connected to 



said network for monitoring and storing characteristic 
10 data about said client terminals and said servers; and 



network for dynamically distributing said data between 
said servers and said terminals as a function of said 
characteristic data, such that a portion of said data is 
15 stored at said client terminals. 

2. The system of claim 1, wherein said network 
is one of a LANnet, a WANnet, the Internet and an 
Intranet . 

3. The system of claim 1, wherein each of said 
20 client terminals are one of a personal computer, an 

organization personal computer, and a stand-alone 
terminal . 



alone terminals further comprise hardware for executing 
25 one of loading smart cards, reading magnetic cards, and 
processing videographics. 



an interfacing system connected to said 



4 . 



The system of claim 3, wherein said stand- 



5. The system of claim 1, wherein each of said 
servers are one of an information server, a transactional 
server, and an external server. 
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6. The system of claim 5, wherein said 
transactional server is operable to perform one of a 
financial transaction and a personal transaction. 

7. The system of claim 1, wherein said network 
5 is a four tier model. 

8. The system of claim 1, wherein said network 
further comprises a graphical user interface for 
displaying a portion of said data on said client 
terminals . 

10 9. The system of claim 1, wherein the system is 

operable to interact with a plurality of third party 
applications . 

10. The system of claim 1, wherein said 
interfacing system is a request broker system. 

15 11. The system of claim 1, further comprising a 

telecommunications device connected to said network for 
accessing said data from said servers. 

12. The system of claim 1, further comprising an 
optimization system for distributing data between said 

20 client terminals and said servers. 

13. The system of claim 1, wherein said 
characteristic data is one of a plurality of static or 
dynamic parameters associated with each of said client 
terminals and a usage pattern associated with said 

25 terminals. 

14. A method for transferring data over a network 
comprising : 
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providing a plurality of client terminals; 

providing a plurality of servers; 

establishing a data communication between 
said client terminals and said servers; and 
5 generating a database of characteristic data 

associated with said clients terminals and servers; and 

dynamically distributing said data between 
said client terminals and said servers as a function of 
said characteristic data in said database such that a 
10 portion of said data resides at said client terminals and 
a portion of said data resides at said servers. 

15. The method of claim 14, further comprising 
providing said client terminals with hardware for one of 
loading smart cards, reading magnetic cards, and 

15 processing videographics. 

16. The method of claim 14, wherein each of said 
client terminals are one of a personal computer, an 
organizational computer, and a stand-alone terminal. 

17. The method of claim 14, further comprising 
20 providing each of said servers as one of a transactional 

server, an information server, and an external server. 

18. The method of claim 17, further comprising 
performing one of a financial transaction and a personal 
transaction. 

25 19. The method of claim 14, further comprising 

providing a graphical user interface to display data on 
said client terminals. 

20. The method of claim 14, wherein the network 
is one of a WANnet, LANnet , Internet, and an Intranet. 
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21. The method of claim 14, wherein said 
establishing step further comprises loading an 
application onto one of said terminals and establishing 
said data communication as a function of specifications 

5 of said application. 

22. The method of claim 14, further comprising a 
telecommunications device connected to said network for 
accessing data from said servers. 

23. The method of claim 14, further comprising 
10 providing an optimization system for distributing said 

data between said client terminals and said servers. 



characteristic data is one of a plurality of static or 
dynamic parameters associated with each of said client 
15 terminals and a usage pattern associated with said 
terminals . 



is a four- tier model. 

26. A computer-based method of processing 
20 information dynamically between a plurality of client 
terminals and a plurality of servers comprising: 

establishing a data communication path 
between said client terminals and said servers; 

generating a database of characteristic data 
25 associated with said clients terminals and servers; and 
dynamically distributing said data between 
said client terminals and said servers as a function of 
said characteristic data in said database such that a 
portion of said data resides at said client terminals and 
30 a portion of said data resides at said servers. 



24 . 



The method of claim 14, wherein said 



25. 



The method of claim 14, wherein said network 
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27. The method of claim 26, further comprising 
providing said client terminals with hardware for one of 
loading smart cards, reading magnetic cards, and 
processing videographics. 

5 28. The method of claim 26, wherein each of said 

terminals are one of a personal computer, an 
organizational computer, and a stand-alone terminal. 

29. The method of claim 26, further comprising 
providing each of said servers as one of a transactional 

10 server, an information server, and an external server. 

30. The method of claim 29, further comprising 
performing one of a financial transaction and a personal 
transaction. 

31. The method of claim 26, further comprising 
15 providing a graphical user interface to display data on 

said client terminals. 

32. The method of claim 26, wherein the network 
is one of a WANnet , LANnet, Internet, and an Intranet. 

33. The method of claim 26, wherein said 
20 establishing step further comprises loading an 

application onto one of said terminals and establishing 
said data communication as a function of specifications 
of said application. 

34. The method of claim 26, further comprising a 
25 telecommunications device connected to said network for 

accessing data from said servers. 
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35. The method of claim 26, further comprising 
providing an optimization system for distributing said 
data between said client terminals and said servers. 

36. The method of claim 26, wherein said 

5 characteristic data is one of a plurality of static or 
dynamic parameters associated with each of said client 
terminals and a usage pattern associated with said 
terminals . 



37. The method of claim 26, wherein said network 
10 is a four-tier model. 



38. A computer program residing in a computer- 
readable medium, comprising instructions for causing a 
computer system to: 

establish a data communication path between a 
15 plurality of client terminals and a plurality of servers; 

generate a database of characteristic data 
associated with said client terminals and said servers; 
and 
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dynamically distribute data between said 
client terminals and said servers as a function of said 
characteristic information in said database such that a 
portion of said distributed data resides at the client 
5 terminal and a portion of said distributed resides at 
said servers. 
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